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AN ARRANGEMENT FOR PROCESSING DATA IN A 
TELECOMMUNICATIONS NETWORK AND A METHOD 
FOR SETTING UP A TELECOMMUNICATIONS 
DATA PROCESSING ARRANGEMENT 

5 This invention relates to switching and operational support systems in the 

area of general telecommunications, and more particularly, to a new type of 
telecommunications data processing arrangement, and to a new type of solution for 
setting up a telecommunications data processing arrangement. 

A telecommunications network consists of multiple network elements such 

10 as telephony switches, gateways or service nodes. A telephony switch, for 

instance, is used to switch speech and data signals coming from another part of 
network. While performing this function the switch also generates a lot of data, 
which is then used for different purposes e.g. billing the customer for the phone 
call, billing another operator for the use of the network, or statistical data 

15 handling. 

In an ordinary telecommunications network the data from different network 
elements is collected by different mediation devices and then forwarded to 
different operational support system applications such as customer billing 
application, customer care application or fraud analysis application. Current 
20 telecommunication data processing arrangements however are usually built 
towards the needs of each new application. 

In the following, the prior art solutions will be described in more detail 

r 

with reference to the accompanying figure 1 which is a block diagram showing a 
telecommunications data processing arrangement according to prior art. 
25 Figure 1 shows a block diagram of a telecommunications data processing 

arrangement according to prior art. A telecommunications data processing 
arrangement according to prior art comprises network elements 1-3, which 
produce event data. The data from network elements 1-3 is collected by mediation 
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devices 4-6 and then forwarded to different operational support systems 7-9 such 
as customer billing system 7, fraud analysis system 8 or customer care system 9. 

The information collected from the network elements 1-3 is usually 
processed by the mediation devices 4-6 to the format required by the respective 
5 operational support systems 7-9. The operational support system applications 7-9 
such as customer billing system application 7, fraud analysis system application 8 
or customer care system application 9 then use this information, for example, in 
their analyses. 

When new operational support system applications 7-9 are introduced or 

10 new requirements are placed on the existing operational support system 

applications 7-9, there is a lot of changes required in the network. These changes 
need to be carried out in the data processing applications, i.e. the mediation 
devices 4-6, in addition to the required changes in the existing operational support 
system applications 7-9. This updating of the different elements in the 

15 telecommunications network environment is an extremely troublesome and time- 
consuming operation. 

The data processing arrangements according to the prior art are very 
inflexible and thus do not provide an adequate solution for the necessary changes 
in the environment. Further the data processing arrangements according to the 

20 prior art are very restricted in the type of changes that are possible as well as in 
how these changes can be carried out. There is no known solution available that 
would provide an adequate solution for the necessary changes in the environment 
to be easily carried out. 

There are also several problems related to the control of a network of data- 

25 processing components. As each of the components have different capacity of 

handling data, there could occur loss of data when a component receives more data 
than it can handle. When there are changes in the architecture there is a lot of 
work needed in the system such as e.g. introduction of new processes. 
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When a change also involves a change in the structure of input data, the 
components need to be updated to handle this new data, but only if all the old data 
is processed before the new data arrives. If components reject input data there 
might be appropriate actions needed in case dataloss is not allowed. 

In the view of the prior art there is a clear need for a new type of a 
telecommunications data processing arrangement and a new type of method for 
setting up a telecommunications data processing arrangement that would allow 
changes to be carried out in the arrangement without having to build or re-build 
telecom data-processing applications. Since the application will be deployed in a 
telecom environment, an uptime of close to 100% is required. This means that the 
telecommunications data processing arrangement should support changes to the 
connections between the data processing components also to be made at runtime. 
Lack of such a solution has already for a quite some time been a stumbling block 
for the further development of the current operational support system applications. 

The aim of this invention is to overcome the drawbacks of the prior art 
solutions and to provide a new type of telecommunications data processing 
arrangement and a new type of method for setting up a telecommunications data 
processing arrangement. 

According to the first aspect of the present invention there is provided an 
arrangement for processing data in a telecommunications network, comprising one 
or more network elements, and operational support systems, which arrangement is 
characterized by that the arrangement further comprises a data processing network 
element, so that the network elements produce the event data and deliver this data 
as input signal data to the data processing network element, and that the data 
processing network element processes the inputted data and generates an output 
signal data towards the different operational support systems, the arrangement 
being further characterized in that the data processing components of the data 
processing network element have a generic component interface and that the 
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arrangement has a flexible architecture for combining the data processing 
components together, where the data processing components are linked together at 
the startup-time of the telecommunications data processing arrangement. There is 
also provided a method for setting up a telecommunications data processing 
5 arrangement in a telecommunications network, where the network elements are 
producing event data used by different operational support systems, which is 
characterized by that the arrangement further comprises a data processing network 
element for processing the input data from the network elements and generating an 
output data towards the operational support systems, in which a flexible 
10 architecture between the data processing components, having a generic component 
interface, is set up by exporting the properties of the available data processing 
components within the telecommunications data processing arrangement, by 
parsing a configuration file of the telecommunications data processing 
arrangement, and by linking the data processing components together at the 
15 startup-time of the telecommunications data processing arrangement. 

A more complete understanding of the method and the arrangement of the 
present invention may be obtained by the preferred embodiments that follow, taken 
in conjunction with the accompanying drawings, wherein: 

Figure 1 is a block diagram of a telecommunications data processing 
20 arrangement according to prior art, 

Figure 2 is a block diagram of a telecommunications data processing 
arrangement according to the present invention, 

Figure 3 is a block diagram flexible architecture solution of a 
telecommunications data processing arrangement according to the present 
25 invention, 

Figure 4 is a diagram of an example of data processing component 
connections in a telecommunications data processing arrangement according to the 
present invention. 
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The prior art solutions have been described in drawing 1. In the following, 
the solution according to the present invention will be described in more detail 
with reference to the accompanying drawings 2-4. 

Figure 2 shows a block diagram of a telecommunications data processing 
5 arrangement according to the present invention. A telecommunications data 
processing arrangement according to the present invention comprises network 
elements 10-12, a data processing network element 13 and operational support 
systems 7-9, such as customer billing system 7, fraud analysis system 8 or 
customer care system 9. The network elements 10-12 can, for example, consist of 
10 telephony switches, gateways and service nodes. 

The network elements 10-12 produce the event data and deliver this data as 
input signal data to the data processing network element 13. The data processing 
network element 13 then processes the inputted data and generates an output signal 
data towards the different operational support systems 7-9. The data processing 
15 network element 13 may be co-located with one network element 11, as shown in 
the figure by means of a dotted box, and thus only process the input signal from 
that element 11. When the data processing network element 13 is not co-located 
with one network element, it processes the input signal from one or more network 
elements. 

20 The telecommunications data processing arrangement according to the 

present invention consists of a flexible data processing component architecture 
combined with a generic component interface. The data processing arrangement 
solves the problem of having to build or re-build telecom data-processing 
applications for every new customer with needs for a new data-processing product, 

25 or for every major change in requirements customers have on a data-processing 
product they already own and use. 

In the data processing arrangement according to the present invention the 
making of changes to the connections between the data processing components are 
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supported also at runtime, which is important as the arrangement is deployed in a 
telecom environment. 

In the data processing arrangement according to the present invention, the 
data processing components of the data processing network element 13 have a 
generic component interface, which is capable of handling the data transfers 
independent from the type of data. In a solution according to the present 
invention, when a certain requirement cannot be met with a combination of the 
existing data processing components that are available within the application as a 
standard, a new component can easily be added. This also benefits other future 
customers with a similar requirement. The connections necessary to be made are 
based on configuration information that is tailored to fit the requirements of the 
customer. 

Figure 3 shows a block diagram flexible architecture solution of a 
telecommunications data processing arrangement according to the present 
invention. In the figure the data processing network element is marked with a 
reference number 13. The data processing network element 13 according to the 
present invention has a database 15, a configuration file 16 and a data processing 
application 17. 

The data processing network element 13 has a database 15 into which the 
incoming input 14 is stored until it is processed. The data processing application 
17 will use the incoming input 14 from the database 15 and the information from 
the configuration file 16 of the application to process the data. The processing 
application 17 will then generate an output signal 18 towards the operational 
support system applications. 

Figure 4 shows a diagram of an example of data processing component 
connections in a telecommunications data processing arrangement according to the 
present invention. In a telecommunications data processing arrangement according 
to the present invention there are three types of components can be distinguished 
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within the data processing system, producer data processing components 19, 20, 
producer/consumer data processing components 21-24 and consumer data 
processing components 25-27. 

Producer data processing component 19, 20 is a component which 
5 communicates with an external entity. Producer data processing component 19, 20 
is used for receiving input, and it produces data towards the producer /consumer 
data processing components 21-24. Producer/consumer data processing 
component 21-24 is a component that consumes data internally to the system, and 
produces a transformed form of that data towards the consumer data processing 
10 components 25-27. Consumer data processing component 25-27 is a component 
that communicates with an external entity for the delivery of the output data. 

In a telecommunications data processing arrangement according to the 
present invention is based on a generic data processing component interface and a 
new architecture solution for combining the data processing components together. 
15 The generic data processing component interface consist of the following concepts: 

adapters that are the interface between the different data processing 
components and accomplish the connection between them, 
synchronization support arrangement for the cases when certain 
components cannot handle the datarate, 
20 - check/back-up support arrangement for the different data processing 

components, and 

configuration change support arrangement. 
In a telecommunications data processing arrangement according to the 
present invention the adapters can cross boundaries between process and machines 
25 when necessary. In the synchronization support arrangement according to the 
present invention when certain components cannot handle the datarate, this is 
signalled back to the components producing the data. This way part of the system 
is blocked until the blocking condition is ceased. The reason for blocking a part of 
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the system is achieving increased reliability of the telecommunications data 
processing arrangement. 

The check/back-up support arrangement according to the present invention 
is used to further increase the reliability. In the arrangement every data processing 
component registers with a checkpoint component and feeds it at a regular basis, 
e.g. every 5 seconds, with information stating which data it has processed and 
safely passed on to the next component without getting lost or duplicated. The 
check/back-up support arrangement flushes this information to disk at a regular 
interval. If the system crashes, the check/back-up support arrangement distributes 
this information over all data processing components which can than continue 
processing the data exactly at the point of the crash. 

When new type of input data has to be processed or when new type of 
output has to be generated, the configuration change support arrangement 
according to the present invention is used to prevent old type of data being mixed 
with new type of data. The input sources are blocked and the system is flushed in 
the front-to-back order. After detecting that the entire system is flushed, the 
system is restarted, the new configuration is picked up by the data processing 
components, and the processing the new type of data is started. 

In a telecommunications data processing arrangement according to the 
present invention the component interface is very flexible. The data processing 
software components can be physically located in different locations such as in a 
same process on the same computer, in multiple processes on the same computer, 
or in multiple processes on multiple computers. 

The flexible architecture solution for combining the data processing 
components together in a telecommunications data processing arrangement 
according to the present invention is based on a solution, where the data 
processing components are linked together at the startup-time or run-time of the 
telecommunications data processing arrangement. These data processing 
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components can be used to build new component clusters and new data processing 
applications. 

The flexible architecture solution according to the present invention is set 
up as follows: 

5 - within the telecommunications data processing arrangement, the 

available data processing components export their properties, which 
among others contain the component parameters and the component 
name, 

a configuration file 16, which dictates which components should be 
10 linked up with each other, is parsed at startup-time or during run- 

time of the telecommunications data processing arrangement. 
The configuration information dictates the internal build-up of the data 
processing components within the data processing application. The component 
link-up configuration file 16 is processed at the start-up of the data processing 
15 application. 

When the telecommunications data processing arrangement needs to 
reconfigure itself during run-time, an external signal is send to the 
telecommunications data processing arrangement to inform it that the end-user 
wants the arrangement to re-read the configuration it has prepared. 
20 In the flexible architecture solution according to the present invention the 

components can be listed in one or more component galleries based on the 
component name. 

The validity of a certain component link-up is checked based on the 
properties of the components in question. Such a configuration file 16 can be 
25 specified in a specially defined language. The language used can be for example 

Network Definition Language, NDL. Following is an example of component link- 
up configuration file 16 
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Fileblocker fb(); 
Blocker b(size = s); 
Printer p(); 

//connect components together 
fb->b->p; 

The example above shows an application using three components; a 
FileBlocker, a Blocker and a Printer processing component. These names must 
match one of the components present in the gallery. The line 'fb- > b- > p' links 
together instantiations of these components to form what is called a network. 
Based on the individual properties of the components it is checked whether they 
can be linked together in the configured way. Data presented to component 
instantiation 'fb' will now be processed by 'fb' and passed on to the next 
component 'b' in the chain and so on. 

Changes to the configuration can be made any time and as soon as the 
telecommunications data processing arrangement is restarted, it is picked up and in 
essence a new telecommunications data processing arrangement with new 
behaviour is born. 

In a telecommunications data processing arrangement according to the 
present invention there is a possibility to combine different data processing 
components together to build new components, component clusters. 

Data processing component clusters are usually formed when only a 
combination of existing data processing components can lead to the required 
functionality. These data processing components are then linked together to form 
a new component, component cluster. A data processing component cluster can be 
multiple levels deep and contain other component clusters. Following is an 
example of a data processing component cluster built of other data processing 
components 
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//instantiate a file reader component 



FileReader fr; 
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Fileblocker fb(); 
Blocker b(size = s); 
Printer p(); 
ObjectCounter c(); 

//connect components within this cluster 

fb->b->p; 

b->c; 

//define input and output of this cluster 
input fb; 
output b; 



//instantiate the cluster "Stream" three times 
Stream sl(s = 50); 
Stream s2(s = 200); 

Stream s3(); //uses default argument s = 100 

//connect file reader to instantiated streams 

fr->sl; 

fr->s2; 

fr->s3 

The above example shows a data processing component cluster which is 
three times in the resulting application to form a network of components. All 
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of them get their input from component 'fir' but behave differently because of the 
parameter that is passed to them. 

With the help of the solution according to the present invention the design, 
development and implementation of new data processing applications is 
5 considerably easier. Also the maintenance of the data processing arrangements 
can be considerably improved. The generic components according to the present 
invention can be made part of a reusable component library for building different 
data processing applications such as for example charging and billing applications, 
data warehouse applications, mediation applications and any other operational 
10 support system applications. 



